<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <button>抽奖</button>
    <script>
        // 1. 封装一个获取随机数rand函数
        function rnd(n,m){
           return Math.floor(Math.random()*(m-n+1)+n);
        }
        // 2. 获取按钮
        let btn = document.querySelector('button');
        // 3. 添加点击事件
        btn.onclick = function(){
              // 4. 创建一个promise实例
              let p = new Promise((res,rej)=>{
                // 4.1 在执行器内设置1s单次定时器
                setTimeout(() => {
                    // 4.2 调用rand()
                    let n = rnd(1,100)
                    // 4.3 判断中奖与否 - 概率30%
                     // 4.3.1 中奖调用resolve
                     // 4.3.2 未中奖调用reject
                    if(n<=30){
                        res(n)
                    }else{
                        rej(n)
                    }
                }, 1000);
              }) 
            // 5. 调用promise实例的then方法
                p.then(val=>{
                    console.log("恭喜你，中奖了，号码为"+val);
                },rea=>{
                    console.log("抱歉，没中奖，号码为"+rea);
                })
                // 5.1 传入resolve/rejec函数
                // 5.2 执行打印结果
        }
      
        
    </script>
</body>

</html>